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DETAILED ACTION 
Response to Amendment 

1. Applicant's arguments/amendment with respect to claims 1-21 have been fully 
considered but are moot in view of the new ground(s) of rejection. 

Claim Rejections - 35 USC §112 

2. The following is a quotation of the second paragraph of 35 U.S.C. 112: 

The specification shall conclude with one or more claims particularly pointing out and distinctly 
claiming the subject matter that the applicant regards as his invention. 

Amendment with respect to claims 1 and 12 has been entered. Therefore, prior 
35 U.S.C 112, second paragraph, rejection of claims 1 and 12 has been 
withdrawn. 

Claim Rejections - 35 USC § 101 

3. 35 U.S.C. 101 reads as follows: 

Whoever invents or discovers any new and useful process, machine, manufacture, or composition of 
matter, or any new and useful improvement thereof, may obtain a patent therefor, subject to the 
conditions and requirements of this title. 

Amendment with respect to claim 12 has been entered. Therefore, prior 35 
U.S.C. 101 rejection of the claim has been withdrawn. 

Claim Rejections - 35 USC § 103 

4. The following is a quotation of 35 U.S.C. 103(a) which forms the basis for all 

obviousness rejections set forth in this Office action: 

(a) A patent may not be obtained though the invention is not identically disclosed or described as set 
forth in section 102 of this title, if the differences between the subject matter sought to be patented and 
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the prior art are such that the subject matter as a whole would have been obvious at the time the 
invention was made to a person having ordinary skill in the art to which said subject matter pertains. 
Patentability shall not be negatived by the manner in which the invention was made. 

5. Claims 1-3, 6, 12-14 & 21 are rejected under 35 U.S.C. 103(a) as being 

unpatentable over Quach (US 6.640.313 B1) and further in view of Dvqon et al (US 

2003/0140138 A1) . 

Claim 1: Quach substantially teaches a program to be executed on a target central 
processing unit (CPU) (eg. col. 4, lines 46-53, fig. 1), the method comprising 
opportunistically scheduling diagnostic testing of CPU registers (col. 2, lines 32-41; 
instructions are provided by an issue module to processor's modes which are 
scheduling to run a diagnostic code in HR mode or scheduling to run program code in 
HP mode; running instructions on a processor in HR mode is interpreted as selecting 
such processor) if an error in the CPU register is indicated, a jump to a 
fault handler routine occurs (e.g. col. 6, lines 5-7), but Quach does not read on 
" scheduling user code instructions " and " opportunistically scheduling diagnostic testing 
of CPU registers so that testing of the CPU registers occurs within normal running of 
the user code instructions ". However, Dvqon et al teaches scheduling user code 
instructions " and " opportunistically scheduling diagnostic testing of CPU registers so 
that testing of the CPU registers occurs within normal running of the user code 
instructions as mentioned in the Applicant’s invention (e.g. [0018], [0032]). Therefore, 
at the time the invention was made, it would have been obvious to a person of ordinary 
skill in the art to implement the system/method of Quach in order to provide an 
automated test system that has the ability to apply test cases to a large number of 
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products operating in a variety of platforms. Furthermore, it is desired to have a test 
system that can automatically collect, store and analyze the results and provide the 
test engineer with appropriate, meaningful feedback on the performance of the product 
(e.g. [0014]). 

Claim 2: Quach and Dvaon et al teach a method as in claim 1 above, further 
comprising: checking a predetermined level of aggressiveness for the scheduling of the 
register diagnostic testing (col. 2, lines 43-50; a check unit is activated in HR mode or 
deactivated in HP mode by compare executing result- Quach). 

Claim 3: Quach and Dvaon et al teach a method as in claim 2 above, further 
comprising: determining a next register to be tested (e.g. col. 11, lines 8-40- Quach). 

Claim 6: Quach and Dvaon et al teach a method as in claim 1 above, wherein the CPU 
registers comprise registers in a general register file (inherent; all processing systems 
comprise register files- Quach). 

Claim 12: Quach substantially teaches a computer-readable medium embedded with a 
compiler program for execution on a target microprocessor (e.g. col. 4, lines 46-53, fig. 
1), the program product comprising executable code configured to opportunistically 
schedule diagnostic testing of registers in the microprocessor (col. 2, lines 32-41; 
instructions are provided by an issue module to processor's modes which are 
scheduling to run a diagnostic code in HR mode or scheduling to run program code in 
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HP mode; running instructions on a processor in HR mode is interpreted as selecting 
such processor), but Quach does not read on " scheduling user code instructions " and 
" opportunistically scheduling diagnostic testing of CPU registers so that testing of the 
CPU registers occurs within normal running of the user code instructions ". However, 
Dygon et al teaches scheduling user code instructions " and " opportunistically 
scheduling diagnostic testing of CPU registers so that testing of the CPU registers 
occurs within normal running of the user code instructions as mentioned in the 
Applicant’s invention (e.g. [0018], [0032]). Therefore, at the time the invention was 
made, it would have been obvious to a person of ordinary skill in the art to implement 
the system/method of Quach in order to provide an automated test system that has the 
ability to apply test cases to a large number of products operating in a variety of 
platforms. Furthermore, it is desired to have a test system that can automatically 
collect, store and analyze the results and provide the test engineer with appropriate, 
meaningful feedback on the performance of the product (e.g. [0014]). 

Claims 13 & 21: Quach and Dygon et al teach a computer-readable program product 
as in claim 12 above, further comprising executable code configured to check a 
predetermined level of aggressiveness for the scheduling of the register diagnostic 
testing (col. 2, lines 43-50; a check unit is activated in HR mode or deactivated in HP 
mode by compare executing result- Quach). 
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Claim 14: Quach and Dvaon et al teach a computer-readable program product as in 

% 

claim 13 above, further comprising executable code configured to determine a next 
register to be tested (e.g. col. 11, lines 8-40- Quach). 



6. Claims 7-10, 17-20 are rejected under 35 U.S.C. 103(a) as being unpatentable 
over Quach and Dvaon et al as applied to claim 1 above, and further in view of Raina 
(US 6. 134. 675) . 

As per claims 7 & 17: Quach and Dvaon et al fails to teach writing known data to a 
register, reading data from the register, and comparing the known data with the data 
that was read but Raina teaches the scheduled diagnostic code performs diagnostic 
operations from a test pattern Comprising comparing an actual result with known 
expected results (col. 3 lines 19-22). Therefore, it would have been obvious to one of 
ordinary skill in the art at the time the invention was made to modify Quach and Dygon 
et al 's teachings the scheduled diagnostic code by performing diagnostic operations 
from a test pattern comprising operations with known expected results as taught by 
Raina in order to improve method that is better suited for testing integrated circuits 
containing multiple core 

As per claims 8, 10, 18 & 20: Quach and Dvaon et al in view of Raina teach a method/ 
a computer-readable program of claims 7 & 17 above, wherein if the comparison 
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indicates a difference, then jumping to a fault handler routine (e.g. col. 3, lines 15-22; 

Raina) . 

As per claims 9 & 19: Quach and Dvaon et al in view of Raina teach a method/ a 
computer-readable program as in claims 8 and 18 above, wherein the fault handler 
routine is configured to halt execution to avoid potential data corruption (e.g. col. 3, lines 
17-19; Raina) . 

7. Claims 4, 5, 11 & 15-16 are rejected under 35 U.S.C. 103(a) as being 
unpatentable over Quach and Dyqon et al in view of Schreiber (US 6.460.173 B1) and 
further in view of Tirumalai et al (US 5.835.776). 

As per claims 4-5 & 15-16: Quach fails to teach if there is sufficient opportunity, then 
scheduling the register diagnostic instruction to test the next register; and if there is 
insufficient opportunity, then scheduling user code instructions. However, Schreiber 
teaches a method and apparatus for selecting operation devices or hardware 
components for a processor comprising an initiation interval for that determines if there 
is sufficient cycle time to perform a specific instruction and if the cycle time is insufficient 
assign adjust the time in order to execute the instructions (e.g. col. 5, lines 53-67 & col. 
6, lines 1-18). 

Therefore, at the time the invention was made, it would have been obvious to a person 
of ordinary skill in the art to use in the method of Quach the initiation interval taught by 
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Schreiber in order to reduce the time required for designing processors, and reduce 
the amount of trial and error used in processor design (e.g. col. 2, lines 24-30; 

Schreiber) . 

Claim 1 1 : Quach substantially teaches a method of compiling a program to be executed 
on a target central processing unit (CPU) (e.g. col. 4, lines 46-53, fig. 1), the method 
comprising: opportunistically scheduling diagnostic testing of CPU registers (col. 2, lines 
32-41; instructions are provided by an issue module to processor's modes which are 
scheduling to run a diagnostic code in HR mode or scheduling to run program code in 
HP mode; running instructions on a processor in HR mode is interpreted as selecting 
such processor ); 

checking a predetermined level of aggressiveness for the scheduling of the register 
diagnostic testing; determining a next register to be tested (col. 2, lines 43-50; a check 
unit is activated in HR mode or deactivated in HP mode by compare executing result). 
But Quach fails to teach determining if there is sufficient opportunity to schedule a 
register diagnostic instruction to test the next register; if there is sufficient opportunity, 
then scheduling the register diagnostic instruction to test the next register; and if there is 
insufficient opportunity, then scheduling user code instructions. However, Schreiber 
teaches a method and apparatus for selecting operation devices or hardware 
components for a processor comprising an initiation interval for that determines if there 
is sufficient cycle time to perform a specific instruction and if the cycle time is insufficient 
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assign adjust the time in order to execute the instructions fe.gr. col. 5, lines 53-67 & col. 
6, lines 1-18). 

Therefore, at the time the invention was made, it would have been obvious to a person 
of ordinary skill in the art to use in the method of Quach the initiation interval taught by 
Schreiber in order to reduce the time required for designing processors, and reduce the 
amount of trial and error used in processor design (e.g. col. 2, lines 24-30; Schreiber) . 
The Combination of Quach and Schreiber fails to explicitly teach a compiler to perform 
the functions mentioned above. However, Tirumalai et al teaches an apparatus and 
methods for scheduling target program instructions during the code optimization pass of 
an optimizing compiler, wherein a register diagnostic instruction is scheduled to test a 
next register or cpu register (e.g. see figs. 7 & 8). 

Therefore, at the time the invention was made, it would have been obvious to a person 
of ordinary skill in the art to implement Quach and Schreiber with apparatus/method of 
Tirumalai et al in order to systematically amortize or reduce “loop overhead” 
instructions (col. 3, lines 1-7; Tirumalai et al) . 

Conclusion 

8. The prior art made of record and not relied upon is considered pertinent to 
applicant's disclosure: 

Rasbold et al teaches a method for scheduling instructions for a processor having 
multiple functional resources wherein the reordering of the instructions is accomplished 
in response to a simulation of the run-time environment of the target machine. The 
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simulation of the run-time environment of the target machine is performed at compile 
time after the machine instructions have been generated by a compiler, or after 
instruction generation by an assembler (see abstract). 

Any inquiry concerning this communication or earlier communications from the 
examiner should be directed to Exr. Merant Guerrier whose telephone number is (571) 
270-1066. The examiner can normally be reached Monday through Thursday from 10: 
30 a.m. to 3:30 p.m. 

If attempts to reach the examiner by telephone are unsuccessful, the examiner’s 
supervisor, Jacques Louis Jacques, can be reached on (571) 272-6962. Draft or 
Informal faxes, which will not be entered in the application, may be submitted directly to 
the examiner at (571) 270-2066. 

Information regarding the status of an application may be obtained from the Patent 
Application Information Retrieval (PAIR) system. Status information for published 
applications may be obtained from either Private PAIR or Public PAIR. Status 
information for unpublished applications is available through Private PAIR only. For 
more information about the PAIR system, see http://pair-direct.uspto.gov. Should you 
have questions on access to the Private PAIR system, contact the Electronic Business 
Center (EBC) at 866-217-9197 (toll-free). If you would like assistance from a USPTO 
Customer Service Representative or access to the automated information system, call 
800-786-9199 (IN USA OR CANADA) or 571-272-1000. 
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